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module rr (dataln. state. dataOut) /• eynthesis syn_hier « -flatten. remove" 



Input tl9:0j 
input HS:0) 
output (19:0) 

wire tl9:0j 



dataln; 

state; 

dataOut; 



dataOutO, dataOutl. dataOut2, dataOut3. dataOut4 . 
dataOutS, dataOute, dataOut?. dataOute, dataOut9, 
dataOutlO. dataOutll. dataOutl2, dataOutl3. dataOutI4. 
dataOutlS, dataOutl€, dataOutl7, dataOutie, dataOutlS; 



prio prioO ( .dataln (dataln) , .en (state (19] ) . 
.dataOut (dataOutO) ) ; 

prio priol ( .dataln( {dataln (0) , dataln [19 : 1] )) , .en(state (0) ) . 
.dataOut ({ dataOut 1 (0) . dataOut 1 (19:1)))); 

prio prio2. (.dataln((dataln(l:0) , dataln (19 :2] )) , .en(state (1) ) . 
.dataOut ({dataOut2 (1:0) . dataOut2 (19:2) ))) ; 

prio prio3 ( ,dataln({dataln(2:0) . dataln (19 :3) )) , .en{state (2) ) . 
.dataOut ({da taOut3 (2:0] , dataOut 3 (19:3) ))) ; 

prio prio4 ( .dataInC {dataln (3 : 0) , dataln (19 :4) )) . .en(state (3) ) . 
.dataOut {{dataOut 4 (3 :0] . dataOut4 (19:4) })) ; 

prio'prioS ( .dataln( {dataln(4 :0] , dataln (19 :S] }) . .en(state (4) ) , 
.dataOut ({dataOutS (4:0). dataOutS (19:5) })) ; 

prio prio6 ( .dataln( {dataln(5 :0] . dataln (19 :€)}) , .en (state (5) ) , 
.dataOut ({ dataOut € [S: 0) . dataOute (19:6] })) ; 

prio prio? ( .dataln ( {dataln (6 : 0] . dataln (19 : 7] } ) , .en (state (€)) . 
.dataOut ({dataOut? (6:0) , dataOut? [19:7] )) ) ; 

prio prioe ( .dataln({dataln(7:0) , dataln (19 : B) )) . .en(state (?) ) . 
.dataOut ( {dataOute (7:0). dataOutS (19:8)})); 

prio prio9 ( .dataln ( {dataln (6 : 0) , dataln (19 : 9) ) ) . . en (state (8) ) , 
.dataOut ( {dataOut 9 (8:0) , dataOut9 (19:9) )) ) ; 

prio priolO ( .dataln( {dataln (9 : 0] , dataln (19 : 10] }) , .en (state (9) ) . 
.dataOut ({dataOutlO (9:0) . dataOutlO (19:10) }) ) ; 

prio prion ( .dataln({dataln(10 :0) . dataln(19 : 11] ) ) « ,en(Btate (10] ) , 
.dataOut ({dataOutll (10:0) , dataOutll (19 : 11} )) ) ; 

prio priol2 ( .dataln( {dataln(ll :0] . dataln (19 : 12] }) . .en (state (11) ) , 
.dataOut ( { dataOut 12 (11:0) . dataOutl2 (19 : 12) }) ) ; 

prio priol3 <.dataln({dataln(12:0) , dataln(19 :13) ) ) . .cn(state (12) ) , 
.dataOut ({ dataOut 13 (12:0) . dataOutl3 [19:13] }) ) ; 

prio priol4 ( .dataln ({dataln (13 :0) . dataln [19 : 14) }) . . en (state (13) ) , 
.dataOut ({dataOut 14 (13:0) , dataOut 14 (19:14) })} ; 

prio priolS (.dataln({dataln(14 :0) , dataln (19 : 15] }) . . en (state (14 ) ) . 
.dataOut ({dataOutl5( 14:0] , dataOut IS [19 : 15) })} ; 

prio prioie ( .dataln({dataln(15:0) , dataln(19:16] }) . . en (state (IS) ) , 
.dataOut ({dataOutie (IS :0) , dataOutlC (19 : 16) ))) ; 

prio priol? ( .dataln({dataln(16 :0) . dataln(19:l?] ) ) . . en (atate (16) ) . 
.dataOut ({dataOut 17 (16:0). dataOut 17 (19 1 1?) )) ) ; 

prio priol8 ( .dataln( {dataln [1? : 0) . dataln (19 : 16) )) , .en (state (17J ) . 
.dataOut ({dataOut 18 (17:0) . dataOutlS (19:18) )) ) ; 

prio priol9 ( .dataln( {dataln [18 : 0) , dataln (19 J )) . . en(Btate ( 16 ] ) , 
.dataOut ({ dataOut 19 (18:0) , dataOut 19 [19] ) ) ) ; 

assign dataOut « ( (dataOut 0 | dataOutl | dataOut2 | dataOut3) | 
(dataOut4 I dataOutS I dataOute I dataOut?) | 
(dataOute ( dataOut9 | dataOutlO | dataOutll) | 
(dataOutl2 I dataOutl3 I dataOutl4 I dataOutlS) | 
(dataOutie | dataOutl? | dataOutie | dataOut 1 9) ) ; 



endmodule // rr 
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module prio (daCaIn, en, dataOuc); 
input (19:0] datain; 
input en; 
output (19:0J dataOut; 



reg (19:0] 



i dataOutO; 



always ®(/*AUTOSENSE* /datain) begin 
i_dataOutO = 20 'dO; 
if (datain [0]) 



else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else 
else : 
else : 
else : 
else if 
end 



(datain [1] ) 
(dataln[2) } 
(dataInO] ) 
(datain [4] ) 
(dataln(5j } 
(datain [6] ) 
(datain [7] ) 
(datain [6] ) 
(datain [9] ) 
(datain [10] ) 
(datain [11] ) 
(dataln(12] ) 
(dataln(13] ) 
(dataln(14] ) 
(datalndS] ) 
(dataln(16) ) 
(dataln[17} ) 
(dataln[18] } 
(dataln(19] } 



i_dataOutO = 
i_dataOutO = 
i_dataOucO = 
i_dataOutO « 
i dataOutO c 
i_dataCXicO * 
i_dataOi:tO = 
i_dataOutO = 
i_dataOutO « 
i_dataOutO = 
i_dataOutO = 
i_dataOutO = 
i_dataOutO = 
i_dataOutO = 
i_dataOutO ^ 
i_dataOutO = 
i_dataOutO = 
i_dataOutO o 
i_dataOutO = 
i dataOutO o 



•■ 2O'h00001 
20'h00002 
20*h00004 
2O'h00008 
20'h00010 
20 'hO0020 
20'h00040 
20'h000e0 
20*h00100 
20'h00200 
20'h00400 
20 'hOOSOO 
20 'hOlOOO 
20'h020OO 
20'h04000, 

20'hoeooo 

20'hl0000 
20*h20000 
20'h40000 
20'h80000 



assign dataOut = {20{en}} & i_dataOutO; 
endmodule // prio 



%o{ 
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module prio (datain, en, dataOut) /* 
input (19:0] datain; 
input en; 
output (19:0J dataOut; 



synthesis syn_hier « "flatten, remove" */; 



reg (4:0) 
reg (4:0] 
reg [4:0]- 
reg (4:0J 
wire [9:0] 
wire (9:0] 



i_dataOutO; 

i_dataOutl ; 

i_dataOut2; 

i_dataOut3 ; 
i_dataOut4; 
i_dataOutS; 



wire 
wire 
wire 



muxCtll; 
muxCtl2; 
muxCtl3 ; 



// Calc in parallel 

assign muxCt 11 = [datain (4 : 0] ; 

assign muxCt 12 = (datain (14 : 10] ; 

assign muxCtl3 = (datain [9 :S] ( muxCtll; 



always ® (/♦AUTOSENSE* /datain) begin 



i_dataOutO = 5'dO; 
if- (dataln(0] ) 
else if (dataind]) 
else if (datalnt2] ) 
else if (dataln(3]) 
else if (dataln(4]) 
end // always 9 ( . . . 



i_dataOutO = 
i_dataOutO = 
i_dataOutO - 
i_dataOutO = 
i dataOutO = 



5'hOl 
5'h02 
5 'h04 

5'hoe 

5 -hlO 



always ® (/*AUTOSENSE* /datain) begin 
i_dataOutl ^ 5'dO; 

if (dataIn(S]) i_dataOutl = S'hOl 

else if (datain (6]) i_dataOutl = 5'h02 

else if (datain (7]) i_dataOutl « 5'h04 

else if (datain (8]) i_dataOutl = S'hOS 

else if (datain [9]) l_dataOutl « S'hlO 
end // always 9 ( . . . 

always ® (/*AUTOSENSE*/dataIn) begin 
i_dataOut2 = S'dO; 

if (datain [10]) i_dataOut2 = 5'hOl 

else if (datalndU) i_dataOut2 « 5'h02 

else if (datain [12]) i_dataOut2 = 5 '1104 

else if (datain [131 ) I_data0ut2 i= S'hoe 

else if (datain [14]) I_data0ut2 = 5'hlO 
end // always e ( . . . 

always ®(/*AUTOSENSE* /datain) begin 
i_dataOut3 = 5'dO; 

if (datain [15]) i_dataOut3 « 5'hOl 

else if (datain [16]) i_dataOut3 « S'h02 

else if (dataind?]) i_dataOut3 « 5'h04 

else if (datalnde]) i_dataOut3 « 5'h08 

else if (dataln[19]) i_dataOut3 b S'hlO 
end // always O ( . . . 



// "Mux" data out 

assign i_dataOut4 = {i_dataOutl & { 5{ -muxCtll } } , i_dataOut0 & {5{muxCtll } ) } ; 

^Oj y assign i_dataOut5 = (i_dataOut3 & { S{ -muxCtl2 ) ) , i_dataOut2 & { 5{muxCtl2) ) ) ; 

assign dataOut = {i_dataOut5 & {l0{en & -muxCtl3)), i_dataOut4 t*{lO{en & muxCtl3)}|; 



endmodule // prio 
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